<!-- subpkg_archive/list/index.vue -->
<script lang="ts" setup>
import { getPatientListApi, removePatientApi } from '@/apis/patient';
import type { PatientItem } from '@/types/patient';
import { onShow } from '@dcloudio/uni-app';
import { ref } from 'vue'

  const swipeOptions = ref([
    {
      text: '删除',
      style: {
        backgroundColor: '#dd524d',
        color: '',
        fontSize: '',
      },
    },
  ])
// 1. 患者列表
  const patinetList = ref<PatientItem[]>([])
  const getPatientList = async () => {
    const res = await getPatientListApi()
    patinetList.value = res
  }

  onShow(()=>{
    getPatientList()
  })

  const onSwipeActionClick = async(id: string, index: number)=>{
    // 调用删除患者接口
    await removePatientApi(id)
    // Vue 实例中的数据也要同步删除
    patinetList.value.splice(index, 1)
  }
</script>

<template>
  <scroll-page>
    <view class="archive-page">
      <view class="archive-tips">最多可添加6人</view>

      <uni-swipe-action>
        <uni-swipe-action-item :right-options="swipeOptions"
         v-for="(item, index) in patinetList" :key="item.id"
        @click="onSwipeActionClick(item.id, index)"
         >
          <view class="archive-card" :class="{ active :item.defaultFlag === 1}">
            <view class="archive-info">
              <text class="name">{{ item.name }}</text>
              <text class="id-card">{{ item.idCard }}</text>
              <text class="default" v-if="item.defaultFlag === 1">默认</text>
            </view>
            <view class="archive-info">
              <text class="gender">{{ item.genderValue }}</text>
              <text class="age">{{item.age}}岁</text>
            </view>
            <navigator hover-class="none" class="edit-link" :url="`/subpkg_archive/form/index?id=${item.id}`">
              <uni-icons type="icon-edit" size="20" color="#16C2A3" custom-prefix="iconfont" />
            </navigator>
          </view>
        </uni-swipe-action-item>
      </uni-swipe-action>

      <!-- 添加按钮 -->
      <view v-if="patinetList.length < 6 " class="archive-card">
        <navigator class="add-link" hover-class="none" url="/subpkg_archive/form/index">
          <uni-icons color="#16C2A3" size="24" type="plusempty" />
          <text class="label">添加患者</text>
        </navigator>
      </view>
    </view>
  </scroll-page>
</template>

<style lang="scss">
  @import './index.scss';
</style>